<template>
	<view class="uni-container">
		<uni-forms ref="form" :value="formData" validate-trigger="submit" err-show-type="toast">
			<uni-forms-item name="type" label="主体" required>
				<uni-data-checkbox :multiple="false" v-model="formData.type" :localdata="formOptions.type_localdata" />
			</uni-forms-item>
			<uni-forms-item name="type_name" label="主体名称" required>
				<uni-easyinput placeholder="企业输入公司名称，个人输入姓名" v-model="formData.type_name" />
			</uni-forms-item>
			<uni-forms-item name="comment" label="备注">
				<textarea placeholder="有敏感词过滤功能。你可以尝试输入含test的文本内容将会被拦截" @input="binddata('comment', $event.detail.value)" class="uni-textarea-border" :value="formData.comment"></textarea>
			</uni-forms-item>
			<uni-forms-item name="username" label="负责人姓名">
				<uni-easyinput placeholder="正则，限输入中文" v-model="formData.username" />
			</uni-forms-item>
			<uni-forms-item name="email" label="邮箱">
				<uni-easyinput placeholder="邮箱" v-model="formData.email" />
			</uni-forms-item>
			<uni-forms-item name="dowload_url" label="下载地址">
				<uni-easyinput placeholder="如：https://uniapp.dcloud.io" v-model="formData.dowload_url" />
			</uni-forms-item>
			<uni-forms-item name="weight" label="体重">
				<uni-easyinput placeholder="限输入 >50 && <=500" type="number" v-model="formData.weight" />
			</uni-forms-item>
			<uni-forms-item name="favorite_book" label="喜欢的书">
				<uni-data-checkbox v-model="formData.favorite_book" collection="book" field="title as text, _id as value" orderby="desc" />
			</uni-forms-item>
			<uni-forms-item name="party_member" label="是否为党员">
				<switch @change="binddata('party_member', $event.detail.value)" :checked="formData.party_member" />
			</uni-forms-item>
			<uni-forms-item name="hobby" label="业余爱好">
				<uni-data-checkbox :multiple="true" v-model="formData.hobby" :localdata="formOptions.hobby_localdata" />
			</uni-forms-item>
			<uni-forms-item name="address" label="地址">
				<uni-data-picker self-field="code" parent-field="parent_code" v-model="formData.address" collection="opendb-city-china"
				 orderby="value asc" field="code as value, name as text"></uni-data-picker>
			</uni-forms-item>

			<view class="uni-button-group">
				<button type="primary" class="uni-button" @click="submit">提交</button>
			</view>
		</uni-forms>
	</view>
</template>

<script>
	/* 
		注意：该文件是由schema2code生成的页面，为演示说明需要将页面作为组件放到 /pages/clientDB/validate内
		故本示例修改了onReady为mounted，并关闭了 140-141行代码，关于提交数据并返回到页面的逻辑
	*/
	import {
		validator
	} from '@/js_sdk/validator/validate-demo.js';

	const db = uniCloud.database();
	const dbCollectionName = 'validate-demo';

	function getValidator(fields) {
		let reuslt = {}
		for (let key in validator) {
			if (fields.indexOf(key) > -1) {
				reuslt[key] = validator[key]
			}
		}
		return reuslt
	}

	export default {
		data() {
			return {
				formData: {
					"type": -1,
					"type_name": "",
					"comment": "",
					"username": "",
					"email": "",
					"dowload_url": "",
					"weight": null,
					"favorite_book": "",
					"party_member": null,
					"hobby": [],
					"address": ""
				},
				formOptions: {
					"type_localdata": [{
							"text": "个人",
							"value": 0
						},
						{
							"text": "企业",
							"value": 1
						}
					],
					"hobby_localdata": [{
							"text": "唱歌",
							"value": "Sing"
						},
						{
							"text": "跳舞",
							"value": "dance"
						},
						{
							"text": "画画",
							"value": "draw"
						}
					]
				},
				rules: {
					...getValidator(["type", "type_name", "comment", "username", "email", "dowload_url", "weight", "favorite_book",
						"party_member", "hobby", "address"
					])
				}
			}
		},
		mounted() {
			this.$refs.form.setRules(this.rules)
		},
		methods: {
			/**
			 * 触发表单提交
			 */
			async submit() {
				uni.showLoading({
					mask: true
				})
				return this.$refs.form.submit().then(async(res) => {
					console.log(res,"000");
					let msg = await this.submitForm(res)
					
					console.log(msg,121399999);
					return res
				}).catch((errors) => {
					uni.hideLoading()
				})
			},

			async submitForm(value) {
				// 使用 clientDB 提交数据
				return await db.collection(dbCollectionName).add(value).then((res) => {
					uni.showToast({
						icon: 'none',
						title: '新增成功'
					})
					//this.getOpenerEventChannel().emit('refreshData')
					//setTimeout(() => uni.navigateBack(), 500)
					return res
				}).catch((err) => {
					uni.showModal({
						content: err.message || '请求服务失败',
						showCancel: false
					})
					return err
				}).finally(() => {
					uni.hideLoading()
				})
			}
		}
	}
</script>

<style>
	.uni-container {
		padding: 15px;
	}

	.uni-input-border,
	.uni-textarea-border {
		width: 100%;
		font-size: 14px;
		color: #666;
		border: 1px #e5e5e5 solid;
		border-radius: 5px;
		box-sizing: border-box;
	}

	.uni-input-border {
		padding: 0 10px;
		height: 35px;

	}

	.uni-textarea-border {
		padding: 10px;
		height: 80px;
	}

	.uni-button-group {
		margin-top: 50px;
		display: flex;
		justify-content: center;
	}

	.uni-button {
		width: 184px;
		padding: 12px 20px;
		font-size: 14px;
		border-radius: 4px;
		line-height: 1;
		margin: 0;
	}
</style>
